package JavaCode.recursion_i.complexity_analysis;

public class Pow {
    public double myPow(double x, int n) {
        if(n<0)
        {
            x=1/x;
            n=-n;
        }
        return help(x,n);
    }

    private double help(double x, int n) {
        if(n==1)return 0d;
        double res=help(x,n/2);
        if(n%2==0)
        {
            res*=res;
        }
        else
        {
            res*=res*x;
        }
        return res;
    }
}
/**
 *  Pow(x, n)
 * 实现 pow(x, n) ，即计算 x 的 n 次幂函数。
 *
 * 示例 1:
 *
 * 输入: 2.00000, 10
 * 输出: 1024.00000
 * 示例 2:
 *
 * 输入: 2.10000, 3
 * 输出: 9.26100
 * 示例 3:
 *
 * 输入: 2.00000, -2
 * 输出: 0.25000
 * 解释: 2-2 = 1/22 = 1/4 = 0.25
 * 说明:
 *
 * -100.0 < x < 100.0
 * n 是 32 位有符号整数，其数值范围是 [−231, 231 − 1] 。
 */
